package random;

import java.util.Arrays;

/**
 * H 指数
 *
 * 给定一位研究者论文被引用次数的数组（被引用次数是非负整数）。编写一个方法，计算出研究者的 h指数。
 * h 指数的定义：h 代表“高引用次数”（high citations），一名科研人员的 h 指数是指他（她）的 （N 篇论文中）总共有 h 篇论文分别被引用了至少 h 次。且其余的N - h篇论文每篇被引用次数不超过 h 次。
 * 例如：某人的 h 指数是 20，这表示他已发表的论文中，每篇被引用了至少 20 次的论文总共有 20 篇。
 */

public class L274 {

    public static void main(String[] args) {

        System.out.println(new L274().hIndex(new int[]{3,0,6,1,5}));
    }

    public int hIndex(int[] citations) {

        Arrays.sort(citations);
        int h = 0;
        int length = citations.length;
        for (int i = 0; i < length; i++) {
            if (citations[i] >= length - i) {
                h = length - i;
                break;
            }
        }
        return h;
    }
}
